@mixin form-grid {
	display: grid;
	grid-template-columns: [start] minmax(0, 1fr) [half] minmax(0, 1fr) [full];
	gap: var(--theme--form--row-gap) var(--theme--form--column-gap);

	/* stylelint-disable-next-line */
	&.with-fill {
		grid-template-columns:
			[start] minmax(0, var(--form-column-max-width)) [half] minmax(0, var(--form-column-max-width))
			[full] 1fr [fill];
	}

	.type-label {
		margin-block-end: 8px;
	}

	.field {
		grid-column: start / fill;

		@media (min-width: 960px) {
			grid-column: start / full;
		}
	}

	.half,
	.half-left,
	.half-space {
		grid-column: start / fill;

		@media (min-width: 960px) {
			grid-column: start / half;
		}
	}

	.half + .half,
	.half-right {
		grid-column: start / fill;

		@media (min-width: 960px) {
			grid-column: half / full;
		}
	}

	.full {
		grid-column: start / fill;

		@media (min-width: 960px) {
			grid-column: start / full;
		}
	}

	.fill {
		grid-column: start / fill;
	}
}
